Skip to content

Conversation

@Awoonyaa
Copy link

No description provided.

@rustbot
Copy link
Collaborator

rustbot commented Jun 21, 2024

Thanks for the pull request, and welcome! The Rust team is excited to review your changes, and you should hear from @JohnTitor (or someone else) some time within the next two weeks.

Please see the contribution instructions for more information. Namely, in order to ensure the minimum review times lag, PR authors and assigned reviewers should ensure that the review label (S-waiting-on-review and S-waiting-on-author) stays updated, invoking these commands when appropriate:

  • @rustbot author: the review is finished, PR author should check the comments and take action accordingly
  • @rustbot review: the author is ready for a review, this PR will be queued again in the reviewer's queue

@arrowd
Copy link

arrowd commented Jun 24, 2024

Some context: On FreeBSD the evdev headers are not part of the base system, but come from a package named evdev-proto. It seems this package should be installed to make this PR compile.

@devnexen You did some FreeBSD PRs already, could you please look at this one too?

@devnexen
Copy link
Contributor

Some context: On FreeBSD the evdev headers are not part of the base system, but come from a package named evdev-proto. It seems this package should be installed to make this PR compile.

Just quick response here: by definition if it is not part of the system thus has no place in this crate, e.g. libutil is still part of builtin libraries. my 2 cents :)

@arrowd
Copy link

arrowd commented Jun 24, 2024

Yes, but on Linux these data types are part of libc. Because of this, the consumers of this library that are using these types will fail to compile on FreeBSD. This is the case for the new release of https://github.com/mqudsi/syngesture

I think that putting these types here is the most correct solution, but I know nothing of Rust ecosystem.

@devnexen
Copy link
Contributor

I get it, but Linux is Linux. However though, nothing is stopping you define those types in the requested project (or to publish a crate dedicated to those sort of things ?). But hey, I m not the maintainer of libc :) I do not get to decide.

@arrowd
Copy link

arrowd commented Jun 24, 2024

nothing is stopping you define those types in the requested project

This would require patching for each project that depends on these types in libc.

or to publish a crate dedicated to those sort of things ?

This would probably require patching too, although much less? Maybe it is a way to go then?

@devnexen
Copy link
Contributor

Regardless, to make CI work here you would need to add the related dependency. CI at the moment only install what necessaty, it appears, for rustup nothing else. The decision to merge it or not is more @JohnTitor call :)

@devnexen
Copy link
Contributor

devnexen commented Jul 5, 2024

I think you need to declare the appropriate evdev-proto header in libc-test/build.rs in the freebsd's list.

@Awoonyaa Awoonyaa force-pushed the libc_upd branch 3 times, most recently from 5d44a74 to 6a00f38 Compare July 10, 2024 08:14
@devnexen
Copy link
Contributor

Also note you need to treat struct field such as input_event::type_ as it is for sure not its real name, see other example how it is done in libc-test/build.rs.

@Awoonyaa
Copy link
Author

Awoonyaa commented Jul 12, 2024

@devnexen thank you for the comments! Maybe you can advise me how to create a flag for checking file in /usr/local/include ?

@devnexen
Copy link
Contributor

@devnexen thank you for the comments! Maybe you can advise me how to create a flag for checking file in /usr/local/include ?

Are you able to run tests locally ?

@Awoonyaa
Copy link
Author

@devnexen thank you for the comments! Maybe you can advise me how to create a flag for checking file in /usr/local/include ?

Are you able to run tests locally ?

Yes

@Awoonyaa Awoonyaa force-pushed the libc_upd branch 2 times, most recently from ac3af67 to f2fb2da Compare July 16, 2024 14:01
cfg.define("_WANT_FREEBSD11_STAT", None);
cfg.define("LIBICONV_PLUG", None);

cfg.flag("-I/usr/local/include");
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ideally, we should use the value of sysctl -n user.localbase here instead of hardcoding "/usr/local", but I don't know how to do it in Rust.

@tgross35 tgross35 changed the title Add structures for freebsd FreeBSD: add evdev structures Aug 16, 2024
@tgross35
Copy link
Contributor

I asked about this as a policy question in #3839. Until then:

@rustbot blocked

@arrowd
Copy link

arrowd commented Dec 22, 2024

@tgross35 Can we get this in? The change does not use headers from 3rd-party packages anymore, so #3839 is now unrelated.

Comment on lines 283 to 297
pub struct input_event {
pub time: crate::timeval,
pub type_: crate::u_short,
pub code: crate::u_short,
pub value: c_int,
}

pub struct input_absinfo {
pub value: c_int,
pub minimum: c_int,
pub maximum: c_int,
pub fuzz: c_int,
pub flat: c_int,
pub resolution: c_int,
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@tgross35
Copy link
Contributor

tgross35 commented Dec 22, 2024

@tgross35 Can we get this in? The change does not use headers from 3rd-party packages anymore, so #3839 is now unrelated.

Thanks for the ping, I didn't realize this was ready (for future reference, @rustbot review updates the labels).

@Awoonyaa one nit above and can you add these to libc-test/semver/freebsd.txt?

Cc @asomers

@rustbot author

@asomers
Copy link
Contributor

asomers commented Dec 22, 2024

The definitions look correct to me. Personally I'd be tempted to expose these under an evdev:: module rather than at the crate root. But Linux already exposes them at the crate root, so I guess the horse has already left the barn.

@tgross35
Copy link
Contributor

The definitions look correct to me. Personally I'd be tempted to expose these under an evdev:: module rather than at the crate root. But Linux already exposes them at the crate root, so I guess the horse has already left the barn.

Thanks for taking a look. I have been thinking that modules mirroring C header paths might be worth doing for 1.0, then only reexporting a common subset for backward compatibility. Especially considering this would make our sources easier to navigate and cross reference to the system headers. But indeed we may as well be consistent here.

@redwan-islam-rumman

This comment was marked as spam.

@redwan-islam-rumman

This comment was marked as spam.

@Awoonyaa Awoonyaa force-pushed the libc_upd branch 2 times, most recently from be9882d to 00e4603 Compare December 23, 2024 10:08
@tgross35 tgross35 added the stable-nominated This PR should be considered for cherry-pick to libc's stable release branch label Dec 23, 2024
@Awoonyaa
Copy link
Author

Can we get this in, please? Or is it something else we need to fix?

@tgross35
Copy link
Contributor

Can we get this in, please? Or is it something else we need to fix?

I believe this is ready except for #3756 (comment)

Copy link
Contributor

@tgross35 tgross35 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks!

@tgross35 tgross35 added this pull request to the merge queue Feb 18, 2025
@tgross35 tgross35 removed this pull request from the merge queue due to a manual request Feb 18, 2025
@tgross35 tgross35 enabled auto-merge February 18, 2025 02:16
@tgross35 tgross35 added this pull request to the merge queue Feb 18, 2025
Merged via the queue into rust-lang:main with commit 068180c Feb 18, 2025
44 checks passed
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Feb 22, 2025
(backport <rust-lang#3756>)
(cherry picked from commit 187468d)
@tgross35 tgross35 mentioned this pull request Feb 22, 2025
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Feb 22, 2025
(backport <rust-lang#3756>)
(cherry picked from commit 187468d)
@tgross35 tgross35 added stable-applied This PR has been cherry-picked to libc's stable release branch and removed stable-nominated This PR should be considered for cherry-pick to libc's stable release branch labels Feb 23, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

O-unix S-waiting-on-author stable-applied This PR has been cherry-picked to libc's stable release branch

Projects

None yet

Development

Successfully merging this pull request may close these issues.